Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@alwatr/delay

Package Overview
Dependencies
Maintainers
0
Versions
10
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@alwatr/delay

Comprehensive toolkit for managing asynchronous operations.

  • 1.0.8
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
125
decreased by-16.11%
Maintainers
0
Weekly downloads
 
Created
Source

@alwatr/delay

@alwatr/delay offers a collection of utility functions to handle asynchronous execution flow effectively. It allows you to pause your code until specific conditions are met or certain events occur. This functionality aids in managing complex asynchronous scenarios and crafting intricate flows with ease. The functions can be used independently or combined for robust control over asynchronous operations.

Installation

npm install @alwatr/delay
yarn add @alwatr/delay

Usage

Each function within @alwatr/delay returns a Promise that resolves when the specified waiting condition is met. Here's a breakdown of the available functions:

  • waitForTimeout(duration: number): Promise

    • Waits for a specified duration (in milliseconds) before resolving.

    • Example:

      import {waitForTimeout} from '@alwatr/delay';
      
      await waitForTimeout(1000); // Waits for 1 second
      
  • waitForAnimationFrame(): Promise

    • Pauses execution until the next animation frame is scheduled, resolving with the current timestamp.

    • Useful for synchronizing UI updates with browser rendering.

    • Example:

      import {waitForAnimationFrame} from '@alwatr/delay';
      
      await waitForAnimationFrame(); // Waits for next animation frame
      
  • waitForIdle(timeout?: number): Promise

    • Waits for the next idle period (when the browser is not busy), resolving with an IdleDeadline object.

    • Optionally accepts a timeout value (in milliseconds) for maximum waiting time.

    • Ideal for executing tasks that don't impact user experience.

    • Example:

      import {waitForIdle} from '@alwatr/delay';
      
      await waitForIdle(); // Waits for next idle period
      
  • waitForDomEvent(element: HTMLElement, eventName: T): Promise<HTMLElementEventMap[T]>

    • Pauses execution until a specific DOM event is triggered on a provided element, resolving with the event object.

    • Example:

      import {waitForDomEvent} from '@alwatr/delay';
      
      const button = document.getElementById('myButton');
      await waitForDomEvent(button, 'click'); // Waits for click event on button
      
  • waitForEvent(target: HasAddEventListener, eventName: string): Promise

    • More generic version of waitForDomEvent, allowing waiting for any event on any object with an addEventListener method.

    • Example:

      import {waitForEvent} from '@alwatr/delay';
      
      const server = http.createServer();
      await waitForEvent(server, 'request'); // Waits for request event on server
      
  • waitForImmediate(): Promise

    • Executes the next task in the microtask queue immediately after the current task finishes.

    • Example:

      import {waitForImmediate} from '@alwatr/delay';
      
      await waitForImmediate(); // Executes next microtask
      
  • waitForMicrotask(): Promise

    • Similar to waitForImmediate, but waits specifically for the next microtask queue.

    • Example:

      import {waitForMicrotask} from '@alwatr/delay';
      
      await waitForMicrotask(); // Waits for next microtask queue
      

Contributing

We welcome contributions to improve this package! Feel free to open bug reports, suggest new features, or submit pull requests following our contribution guidelines.

License:

This package is distributed under the MIT License.

Sponsors

The following companies, organizations, and individuals support Nanolib ongoing maintenance and development. Become a Sponsor to get your logo on our README and website.

Exir Studio

Contributing

Contributions are welcome! Please read our contribution guidelines before submitting a pull request.

License

This project is licensed under the AGPL-3.0 License.

Keywords

FAQs

Package last updated on 02 Nov 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc